PGetObjectIDList

Gets the number of objects on the currently displayed page or pages and gets the ID, group ID, drawing order, type, and coordinates for each, and whether the object is linked and transformed.

This query does not return information about groups; use PGetObjectIDListTop instead.


Query results

PGetObjectIDList is a subclass of PListQuery. This query returns a list of top level objects. For each object, it contains the following information. Make sure that PListQuery::Count() > 0 before referencing these fields.

unsigned long nObjectID;

Unique ID of object
unsigned long nMaskID;
Unique ID of mask object if nObjectID is masked
0 if nObjectID is not masked
unsigned long nGroupID;
0 (always 0 for top-level objects)
short nDrawNumber;
Drawing order number of object
short cTypeOfObject;
0 reserved (currently not used)
1 for text block
2 reserved (currently not used)
3 for line
4 for box
5 for oval
6 for TIFF or bitmap image
7 reserved (currently not used)
8 for PICT
9 for PICT (same as 8)
10 for metafile
11 for EPS
12 for polygon
13 reserved (currently not used)
14 for group
PMBool bTransformed;
false if object has not been transformed
true if object has been transformed
PMBool bLinked;
false if object is not linked to an external file
true if object is linked to an external file
long xLeftOrStart;
x coordinate of left-top handle of object, or starting point of line in twips
long yTopOrStart;
y coordinate of left-top handle of object, or starting point of line in twips
long xRightOrEnd;
x coordinate of bottom-right handle of object, or end point of line in twips
long yBottomOrEnd;
y coordinate of bottom-right handle of object, or end point of line in twips
long xRightOrStart;
x coordinate of right-top handle of object, or starting point of line in twips
long yTopOrStart2;
y coordinate of right-top handle of object, or starting point of line in twips
long xLeftOrEnd;
;x coordinate of bottom-left handle of object, or end point of line in twips
long yBotOrEnd2;
y coordinate of bottom-left handle of object, or end point of line in twips
Facing pages. In double-sided, facing-pages mode, PageMaker returns the object list for both pages.

MiniSave first. Always precede GetObjectList with the PMiniSave command to ensure that all inline graphics are included in the list of objects returned by the query. PageMaker does not add inline graphics to its object list until a publica tion is saved or minisaved.

Coordinates for transformed objects. If the selected object was skewed, rotated, or reflected, the coordinate pairs (xLeftOrStart, yTopOrStart), (xRightOrStart, yTopOrStart2), (xLeftOrEnd, yBotOrEnd2), and (xRightOrEnd, yBottomOrEnd) correspond to the original left-top, right-top, left-bottom, and right-bottom handles, but indicate their current locations.

Coordinates for lines. PageMaker returns the corners of the bounding box for most objects, but returns the starting and end points for lines. The first coordinate pair (xLeftOrStart, yTopOrStart) corresponds to the starting point of the line. The second coordinate pair (xRightOrEnd, yBottomOrEnd) corresponds to the end point of the line. The third and fourth coordinate pairs are irrel evant because they duplicate the values of the first two coordinate pairs.

Where the weight of a line lies in relation to the end points depends upon the type of line and whether the user has flipped the weight of the line with the pointer tool to the other side of the line (horizontal and vertical lines only). The illustration above shows the default locations: horizontal lines hang down from the end points; vertical lines hang to the right of the end points; diagonal lines are centered.

This query does not return fields that specify:

Example. The following example creates a new publication, draws and styles two boxes (of different sizes), and skews the second box. It queries for the ID, drawing number, type, and coordinates of the objects on the page. Notice that although these two objects are different sizes and shapes, their left-top and right-bottom handles overlap, resulting in the same return values. To get more detailed information about transformed objects, use the PGetTransform query. To get more detailed information about linked objects, use the PGetLinkInfo and PGetLinks query.

PNew();
box (0, 0) (3, 1); linestyle onepoint; fillstyle none
box (0, 0) (2, 1); linestyle none; fillstyle solid
skew leftTop -45
minisave
getobjectidlist
--expected reply: 2,1,0,1,4,0,0,0,0,3,1,3,0,0,1,2,0,2,4,1,0,0,0,3,1,2,0,1,1


See also

The PGetObjectLoc and PGetSelectIDList queries



Copyright © 1996, Adobe Systems Incorporated. All rights reserved.

Comments or suggestions? Contact Adobe Developer Support